草庐IT

xml - Xpath 改进

全部标签

ruby - 使用 Ruby 向网络服务器发送 XML 请求

恐怕我没有太多通过网络服务器发布文档(例如XML)的经验,所以如果我对HTTP的理解不足,我深表歉意。我在127.0.0.1上的ruby​​应用程序中设置了一个基本的MongrelWeb服务器端口2000.(服务器)。我在同一台计算机上运行一个单独的Ruby应用程序。(客户)。我需要客户端向服务器发送XML文档。我曾尝试使用Net::HTTP来执行此操作,但我找不到一个明确的示例来告诉我应该做什么。我试过了,但遇到了错误。我已将请求分解,使其尽可能基本:http=Net::HTTP.new("127.0.0.1",2000)http.post('file','query=foo')#x

ruby-on-rails - 如何改进用 `' ` 引用所有数组元素并返回包含所有这些引用和逗号分隔元素的字符串的代码?

我正在使用Rails3.2.2,我想用'引用所有数组元素并返回一个包含所有这些引用和逗号分隔元素的字符串。这时候我在用['a','b','c'].collect{|x|"'#{x}'"}.join(",")#=>"'a','b','c'"但我认为我可以改进上面的代码(也许通过使用一个我不知道的Ruby方法,如果它存在的话)。可能吗? 最佳答案 我用"'#{%w{abc}.join("','")}'"这里是扩展版:'#Startingquote%w{abc}.join("','")#Joinarraywith','delimitert

ruby - 您希望在 Ruby 语言中改进哪些方面?

您希望Ruby(以及更广泛的Ruby社区)改进哪些方面?我读了somewhereRuby是Smalltalk和LISP的私生子,Perl小姐是保姆。我非常尊重Ruby的parent,但我不确定我是否喜欢Perl小姐对child的影响。具体来说,我不喜欢预定义的变量:我需要一个cheatsheet知道他们的意思。你可以说“只是不要使用它们”。好吧,我不...但其他人这样做。当我在网上下载一个插件时,如果我需要去接触源代码,我别无选择,只能获取我的备忘单。我只希望他们能从语言本身中删除这些内容。此外,我认为Ruby是一个移动的目标。我的代码在每次新的Ruby升级时都会出错,即使是次要版本。

ruby - capybara - 使用 xPath 查找正在离开范围内

我正在尝试使用默认的Rails日期、时间和日期时间字段通过Capybara构建一个日期选择器。我正在使用within方法来查找该字段的选择框,但是当我使用xPath查找正确的框时,它会离开within范围并在元素的页面。这是我使用的代码。我正在测试的页面有2个日期时间字段,但由于这个错误,我只能让它更改第一个。目前我有一个div容器,其id包含日期时间字段,但我确实计划切换代码以通过标签查找。moduleMarketronmoduleDateTimedefselect_date(field,options={})date_parse=Date.parse(options[:with])

ruby yaml ypath 像 xpath?

你好,我有一个像这样的yaml文件---data:-date:"2004-06-11"description:Firstdescription-date:"2008-01-12"description:Anotherdescripion我如何为xml执行类似于xpath的“ypath”查询?类似于“获取日期为2004-06-11的描述”YAML.parse_file('myfile.yml').select('/data/*/date==2004-06-11')你是怎么做到的,如果可能的话,我怎样才能类似地通过“ypath”编辑描述?谢谢 最佳答案

ruby - 用于类似正则表达式匹配的 xpath 表达式?

我想在具有特定模式的html文档中搜索divid。我想在正则表达式中匹配这个模式:foo_([[:digit:]]{1.8})使用xpath。上述模式的xpath等价物是什么?我坚持//div[@id="foo_然后什么?如果有人能为它继续一个合法的表达。编辑抱歉,我想我必须详细说明一下。其实不是foo_,它是post_message_顺便说一句,我使用mechanize/nokogiri(ruby​​)这是片段:html_doc=Nokogiri::HTML(open(myfile))message_div=html_doc.xpath('//div[substring(@id,13

ruby - 如何在 XPath 中获取序列的最后一个元素?

在Ruby中,我们可以访问带有负数的数组,如array[-1]以获取数组中的最后一个对象。我如何使用XPath执行此操作?我不能这样做:result=node.xpath('.//ROOT/TAG[-1]/KEY_NAME')我在StackOverflow上找到了一个解决方案,但那是一个仅更改上限以获取元素的查询。这可能会返回最后一项或最后一项和上一项。如果我想在Ruby中只获取前一个元素,如array[-2]怎么办? 最佳答案 您可以在谓词中使用last()访问XPath中的最后一个元素。node.xpath('.//ROOT/T

ruby - 改进仅适用于实例方法吗?

我试图了解Ruby的优化功能,但遇到了一个我不了解的场景。以这个示例代码为例:classTravellerdefwhat_are_youputs"I'maBackpacker"enddefself.preferred_accommodationputs"Hostels"endendmoduleRefinementsmoduleMoneydefwhat_are_youputs"I'macashed-uphedonist!"endmoduleClassMethodsdefpreferred_accommodationputs"ExpensiveHotels"endenddefself.in

ruby - 如何使用 Sinatra 提供 XML 文档?

我有一些XML文档,我想从Sinatra服务器获取这些文档。我做了一些搜索,但找不到任何具体的东西。我确实找到了构建器gem,但我不想从头开始构建文档。我试着做这样的事情get'/'xml='Myname90'bodyxmlend但这会在它周围添加HTML标签。这可能是我所缺少的非常基本的东西。你能给我指出正确的方向吗? 最佳答案 这对于Sinatra来说非常简单:get'/'docontent_type'text/xml'"Luis99"end在获取“/”时,响应将是XML"Luis99"使用正确的content_type。

ruby - 尝试使用 nokogiri 获取 xml 文件中 cdata 标签内的内容

我已经看到了几件事,但到目前为止似乎没有任何效果。我正在使用nokogirionrails3ruby​​1.9.2通过url解析xml。xml的片段如下所示:我正在尝试解析它以获取与NewsLineText关联的文本r=node.at_xpath('.//newslinetext')ifnode.at_xpath('.//newslinetext')s=node.at_xpath('.//newslinetext').textifnode.at_xpath('.//newslinetext')t=node.at_xpath('.//newslinetext').contentifnod